<!--
  * 首页 用户头部信息
-->
<template>
  <a-card class="user-header">
    <a-page-header :title="welcomeSentence">
      <template #subTitle>
        <a-typography-text type="secondary" style="margin-left: 20px">所属部门： {{ departmentName }}</a-typography-text>
      </template>
      <template #extra>
        <a-typography-text type="secondary">{{ dayInfo }}</a-typography-text>
      </template>
      <a-row class="content">
        <span class="left-content">
          <p class="last-login-info">
            <AlertOutlined />{{ lastLoginInfo }}
          </p>
          <a class="sentence" href="#" target="_blank"> <smile-outlined spin /> {{ heartSentence }} </a>
        </span>
        <div class="weather">
          <iframe width="100%" scrolling="no" height="50" frameborder="0" allowtransparency="true"
            src="//i.tianqi.com/index.php?c=code&id=12&icon=1&num=3&site=12"></iframe>
        </div>
      </a-row>
    </a-page-header>
  </a-card>
</template>
<script setup lang="ts">
import { computed } from 'vue';
import { useUserStore } from '/@/store/modules/system/user';
import uaparser from 'ua-parser-js';
import { Solar, Lunar } from 'lunar-javascript';
import _ from 'lodash';
import heartSentenceArray from './heart-sentence';

const userStore = useUserStore();

const departmentName = computed(() => userStore.departmentName);

// 欢迎语
const welcomeSentence = computed(() => {
  let sentence = '';
  let now = new Date().getHours();
  if (now > 0 && now <= 6) {
    sentence = '午夜好，';
  } else if (now > 6 && now <= 11) {
    sentence = '早上好，';
  } else if (now > 11 && now <= 14) {
    sentence = '中午好，';
  } else if (now > 14 && now <= 18) {
    sentence = '下午好，';
  } else {
    sentence = '晚上好，';
  }
  return sentence + userStore.$state.actualName;
});

//上次登录信息
const lastLoginInfo = computed(() => {
  let info = '';
  if (userStore.$state.lastLoginTime) {
    info = info + '上次登录:' + userStore.$state.lastLoginTime;
  }

  if (userStore.$state.lastLoginUserAgent) {
    let ua = uaparser(userStore.$state.lastLoginUserAgent);
    info = info + '; 设备:';
    if (ua.browser.name) {
      info = info + ' ' + ua.browser.name;
    }
    if (ua.os.name) {
      info = info + ' ' + ua.os.name;
    }
    let device = ua.device.vendor ? ua.device.vendor + ua.device.model : null;
    if (device) {
      info = info + ' ' + device + ';';
    }
  }

  if (userStore.$state.lastLoginIpRegion) {
    info = info + '; ' + userStore.$state.lastLoginIpRegion;
  }
  if (userStore.$state.lastLoginIp) {
    info = info + '; ' + userStore.$state.lastLoginIp;
  }
  return info;
});

//日期、节日、节气
const dayInfo = computed(() => {
  //阳历
  let solar = Solar.fromDate(new Date());
  let day = solar.toString();
  let week = solar.getWeekInChinese();
  //阴历
  let lunar = Lunar.fromDate(new Date());
  let lunarMonth = lunar.getMonthInChinese();
  let lunarDay = lunar.getDayInChinese();
  //节气
  let jieqi = lunar.getJieQi();
  let next = lunar.getNextJieQi();
  let nextJieqi = next.getName() + ' ' + next.getSolar().toYmd();

  return `${day} 星期${week}，农历${lunarMonth}月${lunarDay}（当前${jieqi}，${nextJieqi} ）`;
});

// 毒鸡汤
const heartSentence = computed(() => {
  return heartSentenceArray[_.random(0, heartSentenceArray.length - 1)];
});
</script>
<style scoped lang="less">
.user-header {
  width: 100%;
  margin-bottom: 5px;
  padding: 0;

  :deep(.ant-card-body) {
    padding: 0;
  }

  .left-content {
    width: calc(100% - 420px);

    h3 {
      color: rgba(0, 0, 0, 0.75);
    }
  }

  .content {
    display: flex;
    justify-content: space-between;

    .weather {
      width: 400px;
    }
  }

  .last-login-info {
    font-size: 13px;
    color: #333;
    overflow-wrap: break-word;
    padding: 0;
    margin: 1px 0 0 0;
  }

  .sentence {
    display: block;
    font-size: 12px;
    color: #acacac;
    overflow-wrap: break-word;
    padding: 5px 0 0 0;
    margin: 6px 0 0 0;
  }

  .sentence:hover {
    cursor: pointer;
    text-decoration: underline;
  }
}
</style>
